<!DOCTYPE html>
<html >
<head>
    <meta charset="UTF-8">
    <title>Table</title>
    <link rel="stylesheet" href="plugins/layui/css/layui.css" media="all"/>
    <link rel="stylesheet" href="css/global.css" media="all">
    <link rel="stylesheet" href="plugins/font-awesome/css/font-awesome.min.css">
    <link rel="stylesheet" href="css/table.css"/>

</head>

<body>
<div class="admin-main">

    <blockquote class="layui-elem-quote">
        <a href="problem.html" class="layui-btn layui-btn-sm">
            <i class="layui-icon">&#xe608;</i> 返回
        </a>
        <a href="javascript:;" class="layui-btn layui-btn-sm" id="add">
            <i class="layui-icon">&#xe608;</i> 添加试题分类
        </a>
    </blockquote>
    <fieldset class="layui-elem-field">
        <legend>试题分类列表</legend>
        <div class="layui-field-box layui-form">
            <table class="layui-table admin-table">
                <thead>
                <tr>
                    <th style="width: 30px;"><input type="checkbox" lay-filter="allselector" lay-skin="primary"></th>
                    <th>名称</th>
                    <th>别名</th>
                    <th>操作</th>
                </tr>
                </thead>
                <tbody id="content">
                </tbody>
            </table>
        </div>
    </fieldset>
    <div class="admin-table-page">
        <div id="paged" class="page">
        </div>
    </div>
</div>
<!--模板-->
<script type="text/html" id="tpl">
    {{# layui.each(d.value.records, function(index, item){ }}
    <tr>
        <td><input name="id" type="checkbox" lay-skin="primary"></td>
        <td>{{ item.categoryName }}</td>
        <td>{{ item.categorySlug }}</td>
        <td>
            <a href="javascript:;" data-id="{{ item.id }}" data-opt="edit" class="layui-btn layui-btn-xs">编辑</a>
            <a href="javascript:;" data-id="{{ item.id }}" data-opt="del"
               class="layui-btn layui-btn-danger layui-btn-xs">删除</a>
        </td>
    </tr>
    {{# });
    }}
</script>
<script type="text/javascript" src="../my/js/HOST.js"></script>
<script type="text/javascript" src="plugins/layui/layui.js"></script>
<script type="text/javascript" src="js/Global.js"></script>
<script>
    layui.config({
        base: 'js/'
    }).extend({
        busajax: 'busajax'
    });
    layui.use(['paging', 'form', 'busajax'], function () {
        var $ = layui.jquery,
            bajax = layui.busajax,
            paging = layui.paging(),
            layerTips = parent.layer === undefined ? layui.layer : parent.layer, //获取父窗口的layer对象
            layer = layui.layer, //获取当前窗口的layer对象
            form = layui.form();
        //busajax.test();
        //busajax('system.user.insertOrUpdate',"asdas",b);
        var datas = {
            page: {
                current: "1"
            }
        };
        paging.init({
            openWait: true,
            url: HOST+'business.ojProblemCategory.getOjProblemCategoryByPage.hsr', //地址
            elem: '#content', //内容容器
            params: datas,
            type: 'POST',
            tempElem: '#tpl', //模块容器
            pageConfig: { //分页参数配置
                elem: '#paged', //分页容器
                pageSize: 10 //分页大小
            },
            success: function () { //渲染成功的回调
//                alert('渲染成功');
            },
            fail: function (msg) { //获取数据失败的回调
                alert('获取数据失败')
            },
            complate: function () { //完成的回调
//                alert('处理完成');
                //重新渲染复选框
                form.render('checkbox');
                form.on('checkbox(allselector)', function (data) {
                    var elem = data.elem;

                    $('#content').children('tr').each(function () {
                        var $that = $(this);
                        //全选或反选
                        $that.children('td').eq(0).children('input[type=checkbox]')[0].checked = elem.checked;
                        form.render('checkbox');
                    });
                });

                //绑定所有编辑按钮事件
                $('#content').children('tr').each(function () {
                    var $that = $(this);
                    $that.children('td:last-child').children('a[data-opt=edit]').on('click', function () {
//                        layer.msg($(this).data('id'));
                        console.log($(this).data('id'));
                        edit($(this).data('id'));
                    });
                    $that.children('td:last-child').children('a[data-opt=del]').on('click', function () {
                        var _this = $(this);
                        layer.confirm('您确定要删除吗?', {
                            btn: ['确定','取消'], //按钮
                            shade: false //不显示遮罩
                        }, function(index){
                            // 提交表单的代码，需要你自己写，然后用 layer.close 关闭就可以了，取消可以省略
                            var datas = {
                                ojProblemCategory: {
                                    id: _this.data('id')
                                }
                            };
                            bajax.busajax('business.ojProblemCategory.delete', datas, null);
                            layer.close(index);
                        });
                    });

                });

            },
        });

        /* 增加试题分类弹出框 */
        var addBoxIndex = -1;
        $('#add').on('click', function () {
            if (addBoxIndex !== -1)
                return;
            //本表单通过ajax加载 --以模板的形式，当然你也可以直接写在页面上读取
            $.get('form/problemCategoriesAdd.html', null, function (form) {
                addBoxIndex = layer.open({
                    type: 1,
                    title: '添加试题分类',
                    content: form,
                    btn: ['保存', '取消'],
                    shade: false,
                    offset: ['100px', '30%'],
                    area: ['600px', '400px'],
                    maxmin: true,
                    yes: function (index) {
                        //触发表单的提交事件
                        $('form.layui-form').find('button[lay-filter=edit]').click();
                    },
                    full: function (elem) {
                        var win = window.top === window.self ? window : parent.window;
                        $(win).on('resize', function () {
                            var $this = $(this);
                            elem.width($this.width()).height($this.height()).css({
                                top: 0,
                                left: 0
                            });
                            elem.children('div.layui-layer-content').height($this.height() - 95);
                        });
                    },
                    success: function (layero, index) {
                        //弹出窗口成功后渲染表单
                        var form = layui.form();
                        form.render();
                        form.on('submit(edit)', function (data) {
                            var datas = {
                                ojProblemCategory: data.field
                            };
                            //这里可以写ajax方法提交表单
                            bajax.busajax('business.ojProblemCategory.insertOrUpdate', datas, index, function (result) {
//                                alert(result)
                            })
                            return false; //阻止表单跳转。如果需要表单跳转，去掉这段即可。
                        });
                        //console.log(layero, index);
                    },
                    end: function () {
                        addBoxIndex = -1;
                    }
                });
            });
        });

        /* 编辑试题分类弹出框 */
        var editBoxIndex = -1;
        function edit(id) {
            if (editBoxIndex !== -1)
                return;
            //本表单通过ajax加载 --以模板的形式，当然你也可以直接写在页面上读取
            $.get('form/problemCategoriesEdit.html', null, function (form) {
                editBoxIndex = layer.open({
                    type: 1,
                    title: '编辑试题分类',
                    content: form,
                    btn: ['保存', '取消'],
                    shade: false,
                    offset: ['100px', '30%'],
                    area: ['600px', '400px'],
                    maxmin: true,
                    yes: function (index) {
                        //触发表单的提交事件
                        $('form.layui-form').find('button[lay-filter=edit]').click();
                    },
                    full: function (elem) {
                        var win = window.top === window.self ? window : parent.window;
                        $(win).on('resize', function () {
                            var $this = $(this);
                            elem.width($this.width()).height($this.height()).css({
                                top: 0,
                                left: 0
                            });
                            elem.children('div.layui-layer-content').height($this.height() - 95);
                        });
                    },
                    success: function (layero, index) {
                        var categoriesEdit = {
                            ojProblemCategory: {
                                id:id
                            }
                        };
                        var form = layui.form();
                        //这里可以写ajax方法获取表单
                        bajax.busajax('business.ojProblemCategory.get', categoriesEdit, index, function (result) {
                            $('form.layui-form').find('input[name=id]').val(result.value.id);
                            $('form.layui-form').find('input[name=categoryName]').val(result.value.categoryName);
                            $('form.layui-form').find('input[name=categorySlug]').val(result.value.categorySlug);
                            $('form.layui-form').find('select[name=parentId]').attr('select-data',result.value.parentId);
                        },false);
                        //弹出窗口成功后渲染表单
                        form.render();
                        form.on('submit(edit)', function (data) {
                            var datas = {
                                ojProblemCategory: data.field
                            };
                            //这里可以写ajax方法提交表单
                            bajax.busajax('business.ojProblemCategory.insertOrUpdate', datas, index, function (result) {
                            });
                            return false; //阻止表单跳转。如果需要表单跳转，去掉这段即可。
                        });
                    },
                    end: function () {
                        editBoxIndex = -1;
                    }
                });
            });

        }
    });

</script>
</body>

</html>